<template>
  <div id="app">
    <div class="side-bar">
      <tree-menu>
        <!-- 包裹一下 -->
        <template v-for="item of menuData">
          <!-- 有的菜单是没有子项的 -->
          <!-- item.children不存在时才渲染menu-item -->
          <menu-item v-if="!item.children" :key="item.id">
            {{ item.title }}
          </menu-item>

          <!-- 有的菜单是有子项的 -->
          <!-- 再次递归子组件，并传入item到子组件里 -->
          <re-sub-menu :key="item.id" :data="item" v-else> </re-sub-menu>
        </template>
      </tree-menu>
    </div>
  </div>
</template>

<script>
import menuData from "./data/menu";

export default {
  name: "App",
  data() {
    return {
      menuData,
    };
  },
};
</script>

<style lang="scss" scoped>
.side-bar {
  width: 300px;
}
</style>